### The Course Component Library Guide

The Course Component Library, e.g, EEL4713.jar, is available on the course web page.

The md5sum is of EEL4713.jar is 7e69817da70f7930968add480578fb0c .

Please ensure that you are using the correct version.

**Loading** the EEL4713 library From *Project* > *Load Library* > *Jar Library...* select the EEL4713.jar file. Also, put EEL4713.jar in the same folder with the .circ file. You should now have a new folder in your sidebar containing the following components:

**Register File.** A 32-bit wide by 32-registers deep register file. Register $0 is hard-wired to zero at all times, and writes to $0 are ignored. Inputs rA and rB are used to select register values to output on the A and B outputs. When the clock is triggered, if WE is high, the data value at input W is stored in register rW. The register file can be configured to use rising clock edges as trigger (the default), falling edge, or to be level sensitive.

![http://www.cs.cornell.edu/courses/cs3410/2012sp/project/images/regfile.png](data:image/png;base64,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)

**MIPS RAM.** This component is identical to Logisim's regular 32-bit wide, word-addressed RAM component, except the single-bit *sel* input is replaced by a 4-bit input to selectively enable or disable access to individual bytes within a 32-bit word. For instance, if the memory contains the word 0xAABBCCDD at the current address, then *sel*=0011 will access only the least significant halfword (0xCCDD), and *sel*=1000 will access only the most significant byte (0xAA). This component does not have a defined endianness since it is word addressed. Byte addressed memory (either little-endian or big-endian) can be emulated: to access byte-address 4 (the fifth byte in memory) in little-endian mode, one would set *a*=1 (second word) and *sel*=0001 (least significant byte); to access byte-address 4 (the fifth byte in memory) in big-endian mode, one would set *a*=1 (second word) and *sel*=1000 (most significant byte).

**MIPS Program ROM.** A 32-bit wide byte-addressed ROM, with built-in MIPS assembler. Use the attributes panel to load a MIPS assembly file into the ROM. The PC input specifies the address of the current instruction, and must be a multiple of 4. The output is the 32-bit machine code instruction at the PC address, or an error if the PC is invalid. Reading addresses outside the range of code supplied by the assembly file will cause the ROM to output zero, which happens to encode a no-op in MIPS. The assembly language is in the format described in the notes.

![http://www.cs.cornell.edu/courses/cs3410/2012sp/project/images/rom.png](data:image/png;base64,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)

**MIPS ALU.** Computes a result as follows:

|  |  |  |
| --- | --- | --- |
| Op | name | C |
| ---- | ---------------------- | -------------- |
| 000x | shift left | C = B << Sa; |
| 001x | add | C = A + B |
| 0100 | shift right logical | C = B >>> Sa |
| 0101 | shift right arithmetic | C = B >> Sa |
| 011x | subtract | C = A - B |
| 1000 | and | C = A & B |
| 1010 | or | C = A | B |
| 1100 | xor | C = A ^ B |
| 1110 | nor | C = ~(A | B) |
| 1001 | eq | C = (A == B) ? 1 : 0 |
| 1011 | ne | C = (A != B) ? 1 : 0 |
| 1101 | gtz | C = (A > 0) ? 1 : 0 |
| 1111 | lez | C = (A ≤ 0) ? 1 : 0 |

![http://www.cs.cornell.edu/courses/cs3410/2012sp/project/images/alu.png](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABnCAIAAAA/otMHAAAACXBIWXMAAA51AAANiQEDLEHaAAAAB3RJTUUH1wkTFDcC6XXWgwAAArFJREFUeNrtXNuuxCAIFMKP75d7Hkw8rVrFG0KiT5ttq4yiA0NT8N4DgHPOe+8MNoy/ACAgydvv96t0cfYqxBV4NkOrgU+jo92V1dALwCgMLP5rCAZWrpmAgc07lMNA5n1qYWDX3Qph4MAzqmCwABQZkQlDjoln2PdpvTCL45JeDjoVLuzrCAxc3qMwDNzUrxgMrOzL+VEFYCD/eNEJA8WOi00wsDjZAPAcTzMMbHYBAMvZdCGLv3Li0KlwijzJ4oVQIvhPMsDuAGEYBiuh0bzFkXluysQFAzBArTLHdCp0WhtzNfQCYMLQDqAJwwaACozxnPjU1STGAaP1gWizJRcyeQpdABfABXABmAFgrk78z8RLctPzTHzrxJo28a0TyzViyirBesnAm6mvQZc1YidVPlO5+jaSD0g6VTJBX/Nlu04MADiTm1b8dSsTvyoBY668ezMkAnP+ZzSAtJne68yk1vSiyj/CA0dmPYg9idHFoUmtwzCHIxO+3gfAVmJAdk1/AbBo+n8o8SyzFq3XnhNfdfrqQhfABXABbFQlNkkM9ZxdHYDcuCKkYiK2wIV2sGkwdE1OLMDE9SHixDdXII/ZSNJ/OCHjF4avZ0nyxEjUpFy0HEitRAEkKe/XcZRgq6+YEA/w1btoejPIZ6WUC1Ocr3NzMqGl5pm96vXproH4U0aTs1isEfKNCO4+k9ASnwWLmv3zqZxrOR0m7w13B3Nfrhmb9z4yYlGzn2fTmVy8/O50McyqK8b5VQ4lzR8SxNlnzH3clDJ3iDcriaxi0z7dicbmcuzg2hEvUu9E8ilCRu2jLg9havaSQiWt8nJ++KUuJ55n05MAlrDpdlllN5vOXB3MifV8DMR2nbgPgM4qDtk1nQVAf+3s1olVATBcJz7LpsuY2Fad+MXERj9x5pz7A3ca3Cy6u3UqAAAAAElFTkSuQmCC)

**Incrementer.** An adjustable-width incrementer. Takes its input A on the left and outputs A+1 on the right.

![http://www.cs.cornell.edu/courses/cs3410/2012sp/project/images/incr.png](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACIAAAAgCAIAAAD47T2eAAAACXBIWXMAAA51AAANiQEDLEHaAAAAB3RJTUUH1wkTFDYlVWRSqQAAAKVJREFUSMftVkEOgCAMY4SP7+X1QEIUEBiyaQyciJqWjrXTAXDKC4B3JiucOZejE1HcGKnxSw4rKJoSgUANM2e4ANJdMnP/WAAiRLsFiKj8oPqwFP1GQ3fvIO0nWj90DTxYH8WGXqamW8yR9hHQZEDSApqHjdTYogr7EfS2z+/eXsyQUkBjFlQGgd4YtQubTbNpPkQzlwIz/wJPUuB39gwGg8BOzQHr3E5Z4b+BogAAAABJRU5ErkJggg==)

**LCD Video.** If WE is high on the rising edge of CLK, writes a pixel on the LCD screen at the location given by the 7-bit unsigned X and Y coordinates. The pixel color is specified by 16-bit RGB input (in 5-5-5 format). The RST input resets the LCD screen. With some cleverness, you can redirect memory writes to this device to let your program draw on the LCD screen. Logisim also comes with some interesting input and output devices which can be used similarly.

![http://www.cs.cornell.edu/courses/cs3410/2012sp/project/images/video.png](data:image/png;base64,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)

### MIPS (subset) Assembly Syntax

The MIPS Program ROM component has a built-in assembler that understands all of the instructions you will implement. The syntax is standard MIPS syntax. Labels are case sensitive, everything else ignores case. Anything following a pound ('#') is a comment. In project 1, you will only use a few of the instructions listed here.

The instruction syntax is the same as given in the MIPS standard (and different from the output of gcc and many other tools). Registers are written as $0, $1, ..., $31, and the destination register goes on the left, followed by source registers and immediate values on the right. Most integer arguments (immediates, shift amounts, jump targets) can be specified in hex (i.e. 0x12ab), in decimal (i.e. 1234 or -1234), a label, or the special constant PC. The assembler will replace PC with the address of the instruction itself. Most constants have some restrictions: jump destinations must have the same upper 4 bits as the PC+4, and must be a multiple of 4; branch destinations must be a multiple of 4 and fit in a signed 18 bit immediate; etc. As a special case, when a branch target is specified symbolically as a label, the assembler will automatically subtract the current PC value to obtain a signed offset.

By default, the first instruction will be placed at address 0, and subsequent instructions are placed at at addresses 4, 8, 12, etc.

**Assembler directives.** The Program ROM assembler understands two standard MIPS assembler directives, .text and .word, both of which take integer (hex or decimal) arguments. For example, .text 0x50000000 will direct the assembler place subsequent instructions starting at address 0x50000000. And .word 0x24030005 directs the assembler to use the value 0x24030005 as the next machine instruction, which happens to be the machine code for ADDIU $3, $0, 5.

Some examples of instructions are:

|  |  |
| --- | --- |
| Immediate Arithmetic | ADDIU $12, $0, PC |
| Register Arithmetic | ADDU $13, $0, $20 |
| Immediate Load | LUI $14, 0x123 |
| Shifts | SLL $13, $13, 2  SLLV $15, $14, $3 |
| Jumps | J 0x24  J my\_label  JR $5  JALR $31, $5  JALR $5 |
| Branches | BEQ $5, $6, -12  BEQ $5, $6, my\_loop\_top  BLEZ $9, 16  BLEZ $9, my\_loop\_done |
| Memory Load/Store | LW $12, -4($30)  SW $12, 0($30) |

### MIPS (subset) Opcode Summary (from the MIPS Handbook)

Items in white are required for project 1 and project 2. Make sure to decode all of them.

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Table 1: MIPS32 Encoding of the Opcode Field | | | | | | | | | |
| **opcode** | | *bits 28..26 →* | |  | | | | | |
| ↓ bits 31..29 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
| 0 | 000 | *SPECIAL δ* | *REGIMM δ* | J | JAL | BEQ | BNE | BLEZ | BGTZ |
| 1 | 001 | ADDI | ADDIU | SLTI | SLTIU | ANDI | ORI | XORI | LUI |
| 2 | 010 | *COP0 δ* | *COP1 δ* | *COP2 θδ* | *COP3 θδ* | *BEQL φ* | *BNEL φ* | *BLEZL φ* | *BGTZL Φ* |
| 3 | 011 | β | β | β | β | *SPECIAL2 δ* | *JALX ε* | ε | \* |
| 4 | 100 | LB | LH | LWL | LW | LBU | LHU | LWR | β |
| 5 | 101 | SB | SH | SWL | SW | β | β | SWR | CACHE |
| 6 | 110 | LL | LWC1 | LWC2 θ | PREF | β | LDC1 | LDC2 θ | β |
| 7 | 111 | SC | SWC1 | SWC2 θ | \* | β | SDC1 | SDC2 θ | β |

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Table 2: MIPS32 *SPECIAL* Opcode Encoding of the Function Field | | | | | | | | | |
| **function** | | *bits 2..0 →* | |  | | | | | |
| ↓ bits 5..3 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
| 0 | 000 | SLL | *MOVCI δ* | SRL | SRA | SLLV | \* | SRLV | SRAV |
| 1 | 001 | JR | JALR | MOVZ | MOVN | SYSCALL | BREAK | \* | SYNC |
| 2 | 010 | MFHI | MTHI | MFLO | MTLO | β | \* | β | β |
| 3 | 011 | MULT | MULTU | DIV | DIVU | β | β | β | β |
| 4 | 100 | ADD | ADDU | SUB | SUBU | AND | OR | XOR | NOR |
| 5 | 101 | \* | \* | SLT | SLTU | β | β | β | β |
| 6 | 110 | TGE | TGEU | TLT | TLTU | TEQ | \* | TNE | \* |
| 7 | 111 | β | \* | β | β | β | \* | β | β |

|  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Table 3: MIPS32 *SPECIAL* REGIMM Encoding of the rt Field | | | | | | | | | |
| **rt** | | *bits 18..16 →* | |  | | | | | |
| ↓ bits 20..19 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
| 0 | 00 | BLTZ | BGEZ | BLTZL | BGEZL | \* | \* | \* | \* |
| 1 | 01 | TGEI | TGEIU | TLTI | TLTIU | TEQI | \* | TNEI | \* |
| 2 | 10 | BLTZAL | BGETAL | BLTZALL | BGETALL | \* | \* | \* | \* |
| 3 | 11 | \* | \* | \* | \* | \* | \* | \* | \* |